python - Django 测试 VS pytest
全部标签 我有一个简单的函数要测试:func(t*Thing)print(min_verbosityint,messagestring){ift.verbosity>=minv{fmt.Print(message)}}但是我怎样才能测试函数实际发送到标准输出的内容呢?Test::Output在Perl中做我想做的事。我知道我可以编写自己的所有样板文件以在Go中执行相同的操作(如here所述):orig=os.Stdoutr,w,_=os.Pipe()thing.print("Somemessage")varbufbytes.Bufferio.Copy(&buf,r)w.Close()os.Std
我有一个函数可以通过fsnotify监视certian文件并在文件更改时调用回调。如果回调返回false,则观看结束:import("github.com/golang/glog""github.com/fsnotify/fsnotify")typeWatcherFuncfunc(errerror)boolfuncWatchFileChanges(filenamestring,watcherFuncWatcherFunc){watcher,err:=fsnotify.NewWatcher()iferr!=nil{glog.Errorf("Goterrorcreatingwatcher%
我在Golang中有一个调用python函数的API处理程序。我如何模拟来自python函数的响应以避免依赖该函数正确运行来测试Golang函数? 最佳答案 您可以将您的函数包装到一个新的moc函数中:funcCallPythonFunctionMoc()Result{varresResultvarerrerrorres,err=CallPythonFunction()iferr!=nil{res="Mocvalue"}returnres编辑:如果您实际上不想调用python函数,只需返回moc值:funcCallPythonFun
我有一个连接到数据库并检索记录的处理程序。我为此写了一个测试用例,它是这样的:main_test.gopackagemainimport("os""fmt""testing""net/http""net/http/httptest")varaAppfuncTestMain(m*testing.M){a=App{}a.InitializeDB(fmt.Sprintf("postgres://****:****@localhost/db?sslmode=disable"))code:=m.Run()os.Exit(code)}funcTestRulesetGet(t*testing.T){
我有一个使用MySQL的gRPC服务,需要在每个测试用例后清除记录。我尝试用事务来包装每个测试用例。如果我的rpc代码中没有事务,它就可以工作,但如果有,它就会失败。并且会出现如下错误:can'tstarttransaction...sql:Transactionhasalreadybeencommittedorrolledback然后我尝试使用truncate来清除记录,但一些测试用例随机失败。我的代码是这样的(我使用gorm):funcfoo(db*gorm.DB){tx:=db.Begin()//queryandinserttx.Commit()}//Usetransaction
如何测试funcmain?像这样:funcmain(){Engine:=GetEngine()//returnsginrouterwithhandlersatttachedEngine.Run(":8080")}它只有2行,但我想将它们覆盖。TestMain'是为测试准备保留的,这是否意味着测试main不是语言创建者计划的?我可以将内容移动到另一个函数mainReal但它似乎有些过度工程?如何测试gin是否启动良好?我可以在单独的goroutine中启动main,检查回复并停止它吗?谢谢。附言可能的重复不是精确的重复,因为它不是致力于测试funcmain()本身,而是致力于向外移动的想
我有5个端点,它们具有GET、POST和DELETE等方法来测试。我使用go的内置测试包编写了测试用例。我担心我遗漏了一些我不感兴趣的案例。我已经在代码审查中发布了我的测试用例进行审查,但我没有得到任何回应。我也关注了这个帖子TestingHTTProutesingolang.所有这些测试用例都在检查响应代码。问题是,我的大部分测试用例都遵循类似的模式,我以不同的格式发布数据并检查响应代码。我强烈觉得我错过了一些东西,当我将它推向产品时会破坏我的API。我需要对测试这些路由有一些了解,这样我才能有信心将API推向产品。main_test.gofuncTestSigHandler(t*t
我正在使用第三方库,它是一些C函数的包装器。不幸的是,几乎所有的Go函数都是免费的(它们没有接收器,它们不是方法);不是我会采用的设计方法,但它就是我所拥有的。仅使用Go的标准“测试”库:是否有一种解决方案允许我创建可以模拟函数的测试?或者是将库包装成结构和接口(interface),然后模拟接口(interface)来实现我的目标的解决方案?我创建了一个蒙特卡洛模拟,它也处理生成的数据集。我的一种评估算法会寻找特定模型,然后将其传递给第三方函数进行评估。我知道我的边缘情况并且知道调用计数应该是多少,这就是我想要测试的。也许只需要一个简单的计数器?我发现使用这个库的其他项目没有完全覆盖
go程序使用连接字符串连接到数据库。目前该连接字符串存储在环境变量中。我的挑战是编写一个自动化测试,针对测试数据库运行程序。我想我会在测试的init()函数中设置连接字符串环境变量,但是在测试init()之前调用了主程序的init()函数,所以这不起作用。解决方法似乎是将连接字符串默认为测试数据库。如果没有定义环境变量,则使用test;如果已定义(生产),则改用它。有替代方案吗?有没有更好的方法? 最佳答案 我目前的解决方案是使连接成为未初始化的全局连接。该函数检查连接是否为nil-如果是,则将其初始化。该测试有一个setup()函
我知道有hashlib在Python中,但我想获得与下面的Go中相同的结果:packagemainimport("crypto/md5""fmt")funcmain(){data:=[]byte("12345")fmt.Println("sum",md5.Sum(data))}作为funcmd5.Sum描述,它计算“数据的MD5校验和”。但是,我在Python中找不到任何类似的函数。有没有办法像在Go中那样在Python中实现md5.Sum?上面程序的输出是一个slice而不是一个字符串:sum[3244185981728979115075721453575112]